Method data recorder for recording data packet timestamps

ABSTRACT

DVD Rewritable/Re-recordable discs will be used for recording and playing back digital bitstreams, for example MPEG data packets. To enable proper real-time playback of stored MPEG transport packets, a time information is to be added to every data packet to be recorded. A DVD streamer is connected to the application device via an interface, e.g. IEEE 1394. The interface internally uses timestamps having a special format. According to the invention, such interface-generated timestamps are also used for the DVD stream recording, instead of additionally generated independent streamer-specific timestamps. However, a timestamp format conversion is to be carried out because the DVD Streamer timestamp format is different from the IEEE 1394 timestamp format. For such timestamp format conversion differences between consecutive IEEE 1394 timestamps are determined and are used for calculating the DVD stream recording timestamps.

[0001] The invention relates to a method and to a data recorder for converting first data packet timestamps based on a first clock rate to second data packet timestamps based on a second clock rate, for bitstream recording or replaying.

BACKGROUND

[0002] DVD (digital versatile disc) stream recording will be finally specified soon and concerns DVD Rewritable/Re-recordable discs for recording and playing back digital bitstreams including for example MPEG data packets as specified in ISO/IEC 11172, 13818 or 14496. To enable proper real-time playback, e.g. of stored MPEG-2 transport packets according to the DVB-S standard ETS 300 421, a time information is to be added to every data packet to be recorded.

[0003] In WO-A-00/14952 of the applicant it is proposed to use original IEEE 1394 timestamps also in a DVD stream recorder.

INVENTION

[0004] When recording, a DVD streamer receives a data stream from an application device. When replaying, the streamer outputs the replayed data stream to the same or another application device.

[0005] A problem to be solved by the invention is to efficiently provide reference time information required for replaying recorded data packets. This problem is solved by the method disclosed in claim 1.

[0006] A data recorder that utilises this method is disclosed in claim 6.

[0007] A DVD streamer is connected to the application device via an interface. In a home network environment using e.g. IEEE 1394 interfaces, the interface timing generation, or timestamping, and the corresponding interface time reference regeneration is executed in a special IEEE 1394 format. Such interface-generated timestamps could also be used for the DVD stream recording, instead of additionally generating independent streamer-specific timestamps. However, to perform DVD stream recording, a timestamp format conversion is to be carried out because the required DVD Streamer timestamp format is different from above IEEE 1394 timestamp format. The DVD stream recording timestamp format is a 48 bit format using a 27.000 MHz clock frequency according the DVD Specifications for Rewritable/Re-recordable Discs, Part 5 Stream Recording.

[0008] According to the invention, a format conversion is carried out wherein the differences between consecutive interface timestamps are determined and are used for calculating the DVD stream recorder timestamps for the recording. Advantageously, the wraparound-burdened IEEE 1394 timestamps can be converted into the DVD stream recording format thereby avoiding division operations on very long integer data types or floating point operations.

[0009] In principle, the inventive method is suited for converting first data packet timestamps PAT_(A) based on a first clock rate to second data packet timestamps PAT_(B) based on a second clock rate, said clock rates having a ratio B/A, A being derived from said first clock rate and B being derived from said second clock rate, said method including the steps:

[0010] if no PAT_(A) timestamp wraparound takes place, calculating:

D(i)=((PAT _(A)(i)=PAT _(A)(i−1))*B+R(i−1))/A

R(i)=((PAT _(A)(i)−PAT _(A)(i−1))*B+R(i−1))mod A;

[0011] if a PAT_(A) timestamp wraparound takes place between i−1 and i, calculating:

D(i)=((PAT _(A)(i)+PAT _(—) M−PAT _(A)(i−1))*B+R(i−1))/A

R(i)=((PAT _(A)(i)+PAT _(—) M−PAT _(A)(i−1))*B+R(i−1))mod A,

[0012] wherein PAT_(B)(i)=PAT_(B)(i−1)+D(i)

[0013] and wherein (i) denotes a current timestamp, (i−1) denotes a previous timestamp, ‘/’ denotes an integer division, R is a remainder used to avoid the accumulation of rounding errors, and PAT_M is the wraparound value of the timestamp counter of said first clock rate.

[0014] This PAT_M wraparound value is the maximum value possible for PAT_(A) incremented by ‘1’.

[0015] Advantageous additional embodiments of the inventive method are disclosed in the respective dependent claims.

[0016] In principle the data recorder is suited for recording or replaying data packets, using means for converting first data packet timestamps PAT_(A) based on a first clock rate to second data packet timestamps PAT_(B) based on a second clock rate, said clock rates having a ratio B/A, A being derived from said first clock rate and B being derived from said second clock rate, said data recorder including the features:

[0017] if no PAT_(A) timestamp wraparound takes place, calculating:

D(i)=((PAT _(A)(i)−PAT _(A)(i−1))*B+R(i−1))/A

R(i)=((PAT _(A)(i)−PAT _(A)(i−1))*B+R(i−1))mod A;

[0018] if a PAT_(A) timestamp wraparound takes place between i−1 and i, calculating:

D(i)=((PAT _(A)(i)+PAT _(—) M−PAT _(A)(i−1))*B+R(i−1))/A

R(i)=((PAT _(A)(i)+PAT _(—) M−PAT _(A)(i−1))*B+R(i−1))mod A,

[0019] wherein PAT_(B)(i)=PAT_(B)(i−1)+D(i)

[0020] and wherein (i) denotes a current timestamp, (i−1) denotes a previous timestamp, ‘/’ denotes an integer division, R is a remainder used to avoid the accumulation of rounding errors, and PAT_M is the wraparound value of the timestamp counter of said first clock rate.

[0021] Advantageous additional embodiments of the inventive apparatus are disclosed in the respective dependent claims.

DRAWINGS

[0022] Exemplary embodiments of the invention are described with reference to the accompanying drawings, which show in:

[0023]FIG. 1 simplified block diagram for DVD Stream recording via an interface;

[0024]FIG. 2 timestamp format according to the DVD stream recording specification;

[0025]FIG. 3 simplified block diagram for a DVD Stream recording PAT calculator.

EXEMPLARY EMBODIMENTS

[0026] In FIG. 1 an application device APPD is connected to a DVD streamer unit STRU via an interface IF. To APPD belongs interface circuitry: a timestamping & buffering stage TSBI that timestamps and buffers data packets coming from APPD before passing them to IF, and a buffering & timestamping handling stage BTSHI receiving data packets from IF and handling the intermediate buffering and temporally correct delivering of the data packets to APPD.

[0027] In real-time record mode the DVD streamer receives e.g. MPEG-2 transport packets for one or more programs via the IEEE 1394 interface IF. These packets pass through a further buffering & timestamp handling stage BTSHS and a further timestamping & buffering stage TSBS to streamer unit STRU. Replayed data packets coming from STRU pass through a buffering & timing regeneration stage BTRS and a further buffering & timestamping handling stage BTSS to IF.

[0028] Dashed line A-A is the functional border between the streamer-related STRRS stages/unit TSBS, BTRS and STRU, and the interface-related IFRS stages/unit TSBI, BTSHS, BTSS, BTSHI and IF.

[0029] To the DVD streamer STR, which is depicted as a shadowed box, belong unit/stages STRU, BTSHS, TSBS, BTRS and BTSS. The timestamp format according to IEEE 1394 is based on a 24.576 MHz clock and includes two wraparound counters. The first counter output is a 12-bit cycle_offset counting from ‘0’ to ‘3071’ and the second counter output is a 13-bit cycle_count counting from ‘0’ to ‘7999’. By passing the upper boundary limit of the counters, a wraparound to zero is executed. The wraparound of the first counter cycle_offset carries into the second cycle_count field. A complete time period causing one wraparound for cycle_count is exactly 1 sec.

[0030] For real-time data packet handling in a DVD streamer, each DVD transport packet has to carry its own timestamp. Normally, the DVD streamer would generate and record its own timestamps together with the recorded data packets. Such DVD streamer timestamps would thereafter be used in the replaying mode to output the data packets according to the original temporal location at recording time.

[0031] However, the DVD streamer includes an IEEE 1394 interface. Therefore the IEEE 1394 timestamps are already present within the DVD streamer, although their format is not suited for DVD stream recording purposes. In particular the different clock frequencies 24.576 MHz and 27.000 MHz would cause problems because high-precision conversion from one to the other is not trivial. If one could in spite of these problems make use of the IEEE 1394 timestamps, a separate DVD timestamp clock would be superfluous.

[0032] Therefore, if according to the invention for DVD stream recording the IEEE 1394 timestamps are used, their 32-bit/24.576 MHz format has to be converted into the above mentioned 48-bit/27.000 MHz DVD format that is depicted in FIG. 2, wherein PAT denotes the packet arrival time.

[0033] The PAT is composed of PAT_base having a length of 39 bits and PAT_extension having a length of 9 bits. PAT is used for the stream object information. Bit0 . . . bit31 are added to each application packet and bit0 . . . bit40 are used for the system clock reference in DVD stream recording. PAT_(DVDstreamer) for DVD streamer devices has the following properties:

PAT_base(i)=((system_clock*t(i))/300)mod 2³⁹

PAT _(—) exten(i)=(system_clock*t(i))mod 300

PAT _(DVDstreamer)(i)=PAT_base(i)*300+PAT _(—) exten(i)

[0034] wherein ‘/’ denotes an integer division, ‘i’ denotes a current data packet and system_clock has the value 27.000 MHz.

[0035] For a timestamp conversion from IEEE 1394 format to DVD streamer format two problems must be considered:

[0036] The system clock conversion from 24.567 MHz to 27.000 MHz leads to a non-user-friendly factorisation of e.g. 3375/3072 . Other still non-user-friendly factorisations like 1125/1024 are possible.

[0037] The 1-sec-wraparound of the IEEE 1394 timestamp counter.

[0038] The bitlength limit for integer calculation in most processor platforms is at present 32 bits. However, as mentioned above a 48-bit timestamp format is to be handled. To avoid division operations on very high-bitlength integer data types or floating point operations, the following inventive procedure is proposed. The formulas are written in C notation wherein 1% represents the modulo function. The calculations are based on the differences between consecutive IEEE 1394 timestamps.

[0039] For i=0: PAT_(DVDstreamer)(0)=0, i.e. PAT_(start) is advantageously zero. However, PAT_(start) can have any other start value.

[0040] For all other values of ‘i’, temporal differences between consecutive IEEE 1394 timestamps are converted to the DVD streamer format according to:

[0041] if no IEEE1394-timestamp-wraparound {delta_(—)27(i) = ((PAT_(IEEE1394)(i) − PAT_(IEEE1394)(i−1))* 3375 + remainder(i−1)) / 3072

[0042] remainder(i) = ((PAT_(IEEE1394)(i) − PAT_(IEEE1394)(i−1))* 3375 + remainder(i−1)) % 3072 }

[0043] if IEEE1394-timestamp-wraparound {delta_(—)27(i) = ((PAT_(IEEE1394)(i) + PAT_MAX_(IEEE1394) −PAT_(IEEE1394)(i−1)) * 3375 + remainder(i−1)) / 3072

[0044] remainder(i) = ((PAT_(IEEE1394)(i) + PAT_MAX_(IEEE1394) −PAT_(IEEE1394)(i−1)) * 3375 + remainder(i−1)) % 3072 }

[0045] with PAT_MAX_(IEEE1394)=24576000 and remainder(0)=0. Advantageously, the inclusion of a remainder calculation avoids the accumulation of rounding errors.

[0046] The calculation is carried out under the assumption that

(PAT _(IEEE1394)(i)−PAT _(IEEE1394)(i−1))*3375<2^(BL),

[0047] wherein ‘BL’ is the bitlength of the integer calculation involved, i.e. ‘BL’ has in most present processor platforms a value of ‘32’.

[0048] The resulting PATs in the DVD streamer format are

PAT _(DVDstreamer)(i)=PAT _(DVDstreamer)(i−1)+delta_(—)27(i).

[0049] The two elements for a PAT_(DVDstreamer)(i) can be calculated by

PAT _(—) exten(i)=(PAT _(—) exten(i−1)+delta_(—)27(i))% 300

PAT_base(i)=PAT_base(i−1)+(PAT _(—) exten(i−1)+delta_(—)27(i))/300

[0050] This advantageously avoids division operations on 48-bit integers.

[0051] In FIG. 3, a timestamp partitioner TSP collects the required IEEE 1394 timestamps from the bitstream passing interface IF and stage BTSHS. The IEEE 1394 PAT timestamps are sequentially input to memory means M1 and M2, e.g. a shift register holding PAT_(IEEE1394)(i) and PAT_(IEEE1394)(i−1). In each case, the two currently required PAT_(IEEE1394) values are read from M1 and M2 for input into calculator or microprocessor μP, which calculates the PAT_(DVDstreamer) timestamps according to the above formulas.

[0052] Using the above processing for the calculation of the 48-bit DVD stream recording timestamp format is very efficient in particular in view of the application in a real-time system. Division operations on very high-bitlength integer data types and also floating point operations can be avoided.

[0053] The invention can be used correspondingly for any other type of interfaces and any other type of data stream recorders, e.g. CD-related data stream recorders.

[0054] The numbers given can be adapted correspondingly for other applications. 

1. Method for converting first data packet timestamps PAT_(A) based on a first clock rate to second data packet timestamps PAT_(B) based on a second clock rate, said clock rates having a ratio B/A, A being derived from said first clock rate and B being derived from said second clock rate, characterised by the steps: if no PAT_(A) timestamp wraparound takes place, calculating (μP): D(i)=((PAT _(A)(i)−PAT _(A)(i−1))*B+R(i−1))/A R(i)=((PAT _(A)(i)−PAT _(A)(i−1))*B+R(i−1))mod A; if a PAT_(A) timestamp wraparound takes place between i−1 and i, calculating (μP): D(i)=((PAT _(A)(i)+PAT _(—) M−PAT _(A)(i−1))*B+R(i−1))/A R(i)=((PAT _(A)(i)+PAT _(—) M−PAT _(A)(i−1))*B+R(i−1))mod A wherein PAT_(B)(i)=PAT_(B)(i−1)+D(i) and wherein (i) denotes a current timestamp (M1), (i−1) denotes a previous timestamp (M2), ‘/’ denotes an integer division, R is a remainder used to avoid the accumulation of rounding errors, and PAT_M is the wraparound value of the timestamp counter of said first clock rate.
 2. Method according to claim 1, wherein an initial value PAT_(B)(0) of said second data packet timestamps PAT_(B) is zero.
 3. Method according to claim 1 or 2, wherein said second data packet timestamps PAT_(B) are composed of a basic part PAT_(BA) and an extension part PAT_(EX) and are calculated (μP) according to PAT _(EX)(i)=(PAT _(EX)(i−1)+D(i))mod 300 PAT _(BA)(i)=PAT _(BA)(i−1)+(PAT _(EX)(i−1)+D(i))/300.
 4. Method according to one of claims 1 to 3, wherein the bitlengths of said first and second data packet timestamps are different.
 5. Method according to one of claims 1 to 4, wherein said first timestamps stem from an interface (IF), e.g. an IEEE 1394 interface, and wherein said second timestamps are used for recording data packets on a recorder (STR) having included said interface.
 6. Data recorder (STR) for recording or replaying data packets, using means (TSP, M1, M2, μP) for converting first data packet timestamps PAT_(A) based on a first clock rate to second data packet timestamps PAT_(B) based on a second clock rate, said clock rates having a ratio B/A, A being derived from said first clock rate and B being derived from said second clock rate, said data recorder including the features: if no PAT_(A) timestamp wraparound takes place, calculating (μP): D(i)=((PAT _(A)(i)−PAT _(A)(i−1))*B+R(i−1))/A R(i)=((PAT _(A)(i)−PAT _(A)(i−1))*B+R(i−1))mod A; if a PAT_(A) timestamp wraparound takes place between i−1 and i, calculating (μP): D(i)=((PAT _(A)(i)+PAT _(—) M−PAT _(A)(i−1))*B+R(i−1))/A R(i)=((PAT _(A)(i)+PAT _(—) M−PAT _(A)(i−1))*B+R(i−1))mod A wherein PAT_(B)(i)=PAT_(B)(i−1)+D(i) and wherein (i) denotes a current timestamp (M1), (i−1) denotes a previous timestamp (M2), ‘/’ denotes an integer division, R is a remainder used to avoid the accumulation of rounding errors, and PAT_M is the wraparound value of the timestamp counter of said first clock rate.
 7. Data recorder according to claim 6, wherein an initial value PAT_(B)(0) of said second data packet timestamps PAT_(B) is zero.
 8. Data recorder according to claim 6 or 7, wherein said second data packet timestamps PAT_(B) are composed of a basic part PAT_(BA) and an extension part PAT_(EX) and are calculated (μP) according to PAT _(EX)(i)=(PAT _(EX)(i−1)+D(i))mod 300 PAT _(BA)(i)=PAT _(BA)(i−1)+(PAT _(EX)(i−1)+D(i))/300.
 9. Data recorder according to one of claims 6 to 8, wherein the bitlengths of said first and second data packet timestamps are different.
 10. Data recorder according to one of claims 6 to 9, wherein said first timestamps stem from an interface (IF), e.g. an IEEE 1394 interface, and wherein said second timestamps are used for recording data packets on said data recorder having included said interface. 